<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1">
    <title>webdoc</title>
    <link rel="stylesheet" type="text/css" href="../static/css/main.css">
</head>
<body>
<div class="nav">
    <div class="logo">
        
            webdoc
        
    </div>
<ul><li><a href="../index.html">0.Async</a></li><li><a href="../html/0.editor.html">0.editor</a></li><li><a href="../html/0.module.html">0.module</a></li><li><a href="../html/1.ES2015.html">1.ES2015</a></li><li><a href="../html/2.Promise.html">2.Promise</a></li><li><a href="../html/3.Node.html">3.Node</a></li><li><a href="../html/4.NodeInstall.html">4.NodeInstall</a></li><li><a href="../html/5.REPL.html">5.REPL</a></li><li><a href="../html/6.NodeCore.html">6.NodeCore</a></li><li class="active"><a href="../html/7.module&NPM.html">7.module&NPM</a></li><li><a href="../html/8.Encoding.html">8.Encoding</a></li><li><a href="../html/9.Buffer.html">9.Buffer</a></li><li><a href="../html/10.fs.html">10.fs</a></li><li><a href="../html/11.Stream-1.html">11.Stream-1</a></li><li><a href="../html/11.Stream-2.html">11.Stream-2</a></li><li><a href="../html/11.Stream-3.html">11.Stream-3</a></li><li><a href="../html/11.Stream-4.html">11.Stream-4</a></li><li><a href="../html/12-Network-2.html">12-Network-2</a></li><li><a href="../html/12.NetWork-3.html">12.NetWork-3</a></li><li><a href="../html/12.Network-1.html">12.Network-1</a></li><li><a href="../html/13.tcp.html">13.tcp</a></li><li><a href="../html/14.http-1.html">14.http-1</a></li><li><a href="../html/14.http-2.html">14.http-2</a></li><li><a href="../html/15.compress.html">15.compress</a></li><li><a href="../html/16.crypto.html">16.crypto</a></li><li><a href="../html/17.process.html">17.process</a></li><li><a href="../html/18.yargs.html">18.yargs</a></li><li><a href="../html/19.cache.html">19.cache</a></li><li><a href="../html/20.action.html">20.action</a></li><li><a href="../html/21.https.html">21.https</a></li><li><a href="../html/22.cookie.html">22.cookie</a></li><li><a href="../html/23.session.html">23.session</a></li><li><a href="../html/24.express-1.html">24.express-1</a></li><li><a href="../html/24.express-2.html">24.express-2</a></li><li><a href="../html/24.express-3.html">24.express-3</a></li><li><a href="../html/24.express-4.html">24.express-4</a></li><li><a href="../html/25.koa-1.html">25.koa-1</a></li><li><a href="../html/26.webpack-1-basic.html">26.webpack-1-basic</a></li><li><a href="../html/26.webpack-2-optimize.html">26.webpack-2-optimize</a></li><li><a href="../html/26.webpack-3.tapable.html">26.webpack-3.tapable</a></li><li><a href="../html/26.webpack-4-AST.html">26.webpack-4-AST</a></li><li><a href="../html/26.webpack-5-source.html">26.webpack-5-source</a></li><li><a href="../html/26.webpack-6-loader.html">26.webpack-6-loader</a></li><li><a href="../html/26.webpack-7-plugin.html">26.webpack-7-plugin</a></li><li><a href="../html/26.webpack-8-hand.html">26.webpack-8-hand</a></li><li><a href="../html/27.react-1.html">27.react-1</a></li><li><a href="../html/27.react-2.html">27.react-2</a></li><li><a href="../html/27.react-3.html">27.react-3</a></li><li><a href="../html/27.react-4-immutable.html">27.react-4-immutable</a></li><li><a href="../html/27.react-5-react-dom-diff.html">27.react-5-react-dom-diff</a></li><li><a href="../html/27.react-6.html">27.react-6</a></li><li><a href="../html/28.react-mobx.html">28.react-mobx</a></li><li><a href="../html/28.redux-0.html">28.redux-0</a></li><li><a href="../html/28.redux-1.html">28.redux-1</a></li><li><a href="../html/28.redux-2-中间件.html">28.redux-2-中间件</a></li><li><a href="../html/28.redux-3-saga.html">28.redux-3-saga</a></li><li><a href="../html/28.redux-jwt-back.html">28.redux-jwt-back</a></li><li><a href="../html/28.redux-jwt-front.html">28.redux-jwt-front</a></li><li><a href="../html/29.mongodb-1.html">29.mongodb-1</a></li><li><a href="../html/29.mongodb-2.html">29.mongodb-2</a></li><li><a href="../html/29.mongodb-3.html">29.mongodb-3</a></li><li><a href="../html/29.mongodb-4.html">29.mongodb-4</a></li><li><a href="../html/29.mongodb-5.html">29.mongodb-5</a></li><li><a href="../html/29.mongodb-6.html">29.mongodb-6</a></li><li><a href="../html/30.cms-1-mysql.html">30.cms-1-mysql</a></li><li><a href="../html/30.cms-2-mysql.html">30.cms-2-mysql</a></li><li><a href="../html/30.cms-3-mysql.html">30.cms-3-mysql</a></li><li><a href="../html/30.cms-4-egg.html">30.cms-4-egg</a></li><li><a href="../html/30.cms-5-api.html">30.cms-5-api</a></li><li><a href="../html/30.cms-6-roadhog.html">30.cms-6-roadhog</a></li><li><a href="../html/30.cms-7-umi.html">30.cms-7-umi</a></li><li><a href="../html/30.cms-8-dva.html">30.cms-8-dva</a></li><li><a href="../html/30.cms-9-dva.html">30.cms-9-dva</a></li><li><a href="../html/30.cms-10-dva.html">30.cms-10-dva</a></li><li><a href="../html/30.cms-11-front.html">30.cms-11-front</a></li><li><a href="../html/31.cms-12-api.html">31.cms-12-api</a></li><li><a href="../html/31.cms-13-front.html">31.cms-13-front</a></li><li><a href="../html/31.cms-14-deploy.html">31.cms-14-deploy</a></li><li><a href="../html/32.ant.html">32.ant</a></li><li><a href="../html/33.redis.html">33.redis</a></li><li><a href="../html/34.unittest.html">34.unittest</a></li><li><a href="../html/35.jwt.html">35.jwt</a></li><li><a href="../html/36.websocket-1.html">36.websocket-1</a></li><li><a href="../html/36.websocket-2.html">36.websocket-2</a></li><li><a href="../html/38.chat-api-1.html">38.chat-api-1</a></li><li><a href="../html/38.chat-api-2.html">38.chat-api-2</a></li><li><a href="../html/38.chat-3.html">38.chat-3</a></li><li><a href="../html/38.chat-api-3.html">38.chat-api-3</a></li><li><a href="../html/38.chat.html">38.chat</a></li><li><a href="../html/38.chat2.html">38.chat2</a></li><li><a href="../html/38.chat2.html">38.chat2</a></li><li><a href="../html/39.crawl-0.html">39.crawl-0</a></li><li><a href="../html/39.crawl-1.html">39.crawl-1</a></li><li><a href="../html/39.crawl-2.html">39.crawl-2</a></li><li><a href="../html/40.deploy.html">40.deploy</a></li><li><a href="../html/41.safe.html">41.safe</a></li><li><a href="../html/42.test.html">42.test</a></li><li><a href="../html/43.nginx.html">43.nginx</a></li><li><a href="../html/44.enzyme.html">44.enzyme</a></li><li><a href="../html/45.docker.html">45.docker</a></li><li><a href="../html/46.elastic.html">46.elastic</a></li><li><a href="../html/47.oauth.html">47.oauth</a></li><li><a href="../html/48.wxpay.html">48.wxpay</a></li><li><a href="../html/49.nunjucks.html">49.nunjucks</a></li><li><a href="../html/50.ketang.html">50.ketang</a></li><li><a href="../html/index.html">index</a></li><li><a href="../html/51.typescript.html">51.typescript</a></li><li><a href="../html/52.UML.html">52.UML</a></li><li><a href="../html/53.design.html">53.design</a></li><li><a href="../html/index.html">index</a></li></ul></div>


<div class="warpper">

    <div class="page-toc">
        <ul><li><a href="#t01. JS模块化方面的不足">1. JS模块化方面的不足</a></li><li><a href="#t12. CommonJS规范">2. CommonJS规范</a></li><li><a href="#t23. Node中的CommonJS">3. Node中的CommonJS</a></li><li><a href="#t34. 模块分类">4. 模块分类</a><ul><li><a href="#t44.1 原生模块">4.1 原生模块</a></li><li><a href="#t54.2 文件模块">4.2 文件模块</a></li><li><a href="#t64.3 第三方模块">4.3 第三方模块</a><ul><li><a href="#t74.3.1 . 全局目录">4.3.1 . 全局目录</a></li></ul></li><li><a href="#t84.4 模块的加载策略">4.4 模块的加载策略</a></li><li><a href="#t94.5 文件模块查找规则">4.5 文件模块查找规则</a></li></ul></li><li><a href="#t105. 从模块外部访问模块内的成员">5. 从模块外部访问模块内的成员</a></li><li><a href="#t116. 模块对象的属性">6. 模块对象的属性</a></li><li><a href="#t127. 包">7. 包</a></li><li><a href="#t138. NPM">8. NPM</a><ul><li><a href="#t148.1 npm提供的功能">8.1 npm提供的功能</a></li><li><a href="#t158.2npm命令">8.2npm命令</a><ul><li><a href="#t168.2.1 安装包">8.2.1 安装包</a></li><li><a href="#t178.2.2 卸载包">8.2.2 卸载包</a></li><li><a href="#t188.2.3 更新包">8.2.3 更新包</a></li></ul></li><li><a href="#t198.3包的安装模式">8.3包的安装模式</a><ul><li><a href="#t208.3.1 本地安装">8.3.1 本地安装</a></li></ul></li><li><a href="#t218.4 全局安装">8.4 全局安装</a></li><li><a href="#t228.5 注册、登录和发布模块">8.5 注册、登录和发布模块</a></li></ul></li><li><a href="#t23参考资料">参考资料</a></li><li><a href="#t249. yarn">9. yarn</a><ul><li><a href="#t259.1 初始化一个新的项目">9.1 初始化一个新的项目</a></li><li><a href="#t269.2 添加一个依赖包">9.2 添加一个依赖包</a></li><li><a href="#t279.3 更新一个依赖包">9.3 更新一个依赖包</a></li><li><a href="#t289.4 删除一个依赖包">9.4 删除一个依赖包</a></li><li><a href="#t299.5 安装所有的依赖包">9.5 安装所有的依赖包</a></li></ul></li><li><a href="#t30参考">参考</a></li></ul>
    </div>
    
    <div class="content markdown-body">
        <h2 id="t01. JS&#x6A21;&#x5757;&#x5316;&#x65B9;&#x9762;&#x7684;&#x4E0D;&#x8DB3;">1. JS&#x6A21;&#x5757;&#x5316;&#x65B9;&#x9762;&#x7684;&#x4E0D;&#x8DB3; <a href="#t01. JS&#x6A21;&#x5757;&#x5316;&#x65B9;&#x9762;&#x7684;&#x4E0D;&#x8DB3;"> # </a></h2>
<ul>
<li>JS&#x6CA1;&#x6709;&#x6A21;&#x5757;&#x7CFB;&#x7EDF;&#xFF0C;&#x4E0D;&#x652F;&#x6301;&#x5C01;&#x95ED;&#x7684;&#x4F5C;&#x7528;&#x57DF;&#x548C;&#x4F9D;&#x8D56;&#x7BA1;&#x7406;</li>
<li>&#x6CA1;&#x6709;&#x6807;&#x51C6;&#x5E93;&#xFF0C;&#x6CA1;&#x6709;&#x6587;&#x4EF6;&#x7CFB;&#x7EDF;&#x548C;IO&#x6D41;API</li>
<li>&#x4E5F;&#x6CA1;&#x6709;&#x5305;&#x7BA1;&#x7406;&#x7CFB;&#x7EDF;</li>
</ul>
<h2 id="t12. CommonJS&#x89C4;&#x8303;">2. CommonJS&#x89C4;&#x8303; <a href="#t12. CommonJS&#x89C4;&#x8303;"> # </a></h2>
<ul>
<li>&#x5C01;&#x88C5;&#x529F;&#x80FD;</li>
<li>&#x5C01;&#x95ED;&#x4F5C;&#x7528;&#x57DF;</li>
<li>&#x53EF;&#x80FD;&#x89E3;&#x51B3;&#x4F9D;&#x8D56;&#x95EE;&#x9898;</li>
<li>&#x5DE5;&#x4F5C;&#x6548;&#x7387;&#x66F4;&#x9AD8;&#xFF0C;&#x91CD;&#x6784;&#x65B9;&#x4FBF;</li>
</ul>
<h2 id="t23. Node&#x4E2D;&#x7684;CommonJS">3. Node&#x4E2D;&#x7684;CommonJS <a href="#t23. Node&#x4E2D;&#x7684;CommonJS"> # </a></h2>
<ul>
<li>&#x5728;node.js &#x91CC;&#xFF0C;&#x6A21;&#x5757;&#x5212;&#x5206;&#x6240;&#x6709;&#x7684;&#x529F;&#x80FD;&#xFF0C;&#x6BCF;&#x4E2A;JS&#x90FD;&#x662F;&#x4E00;&#x4E2A;&#x6A21;&#x5757;</li>
<li>&#x5B9E;&#x73B0;require&#x65B9;&#x6CD5;,NPM&#x5B9E;&#x73B0;&#x4E86;&#x6A21;&#x5757;&#x7684;&#x81EA;&#x52A8;&#x52A0;&#x8F7D;&#x548C;&#x5B89;&#x88C5;&#x4F9D;&#x8D56;<pre><code>(function(exports,require,module,__filename,__dirname){
  exports = module.exports={}
  exports.name = &apos;zfpx&apos;;
  exports = {name:&apos;zfpx&apos;};
  return module.exports;
})
</code></pre></li>
</ul>
<h2 id="t34. &#x6A21;&#x5757;&#x5206;&#x7C7B;">4. &#x6A21;&#x5757;&#x5206;&#x7C7B; <a href="#t34. &#x6A21;&#x5757;&#x5206;&#x7C7B;"> # </a></h2>
<h3 id="t44.1 &#x539F;&#x751F;&#x6A21;&#x5757;">4.1 &#x539F;&#x751F;&#x6A21;&#x5757; <a href="#t44.1 &#x539F;&#x751F;&#x6A21;&#x5757;"> # </a></h3>
<p><code>http</code> <code>path</code> <code>fs</code> <code>util</code> <code>events</code> &#x7F16;&#x8BD1;&#x6210;&#x4E8C;&#x8FDB;&#x5236;,&#x52A0;&#x8F7D;&#x901F;&#x5EA6;&#x6700;&#x5FEB;&#xFF0C;&#x539F;&#x6765;&#x6A21;&#x5757;&#x901A;&#x8FC7;&#x540D;&#x79F0;&#x6765;&#x52A0;&#x8F7D;</p>
<h3 id="t54.2 &#x6587;&#x4EF6;&#x6A21;&#x5757;">4.2 &#x6587;&#x4EF6;&#x6A21;&#x5757; <a href="#t54.2 &#x6587;&#x4EF6;&#x6A21;&#x5757;"> # </a></h3>
<p>&#x5728;&#x786C;&#x76D8;&#x7684;&#x67D0;&#x4E2A;&#x4F4D;&#x7F6E;&#xFF0C;&#x52A0;&#x8F7D;&#x901F;&#x5EA6;&#x975E;&#x5E38;&#x6162;&#xFF0C;&#x6587;&#x4EF6;&#x6A21;&#x5757;&#x901A;&#x8FC7;&#x540D;&#x79F0;&#x6216;&#x8DEF;&#x5F84;&#x6765;&#x52A0;&#x8F7D;
&#x6587;&#x4EF6;&#x6A21;&#x5757;&#x7684;&#x540E;&#x7F00;&#x6709;&#x4E09;&#x79CD;</p>
<ul>
<li>&#x540E;&#x7F00;&#x540D;&#x4E3A;.js&#x7684;JavaScript&#x811A;&#x672C;&#x6587;&#x4EF6;,&#x9700;&#x8981;&#x5148;&#x8BFB;&#x5165;&#x5185;&#x5B58;&#x518D;&#x8FD0;&#x884C;</li>
<li>&#x540E;&#x7F00;&#x540D;&#x4E3A;.json&#x7684;JSON&#x6587;&#x4EF6;,fs &#x8BFB;&#x5165;&#x5185;&#x5B58; &#x8F6C;&#x5316;&#x6210;JSON&#x5BF9;&#x8C61;</li>
<li>&#x540E;&#x7F00;&#x540D;&#x4E3A;.node&#x7684;&#x7ECF;&#x8FC7;&#x7F16;&#x8BD1;&#x540E;&#x7684;&#x4E8C;&#x8FDB;&#x5236;C/C++&#x6269;&#x5C55;&#x6A21;&#x5757;&#x6587;&#x4EF6;,&#x53EF;&#x4EE5;&#x76F4;&#x63A5;&#x4F7F;&#x7528;<blockquote>
<p>&#x4E00;&#x822C;&#x81EA;&#x5DF1;&#x5199;&#x7684;&#x901A;&#x8FC7;&#x8DEF;&#x5F84;&#x6765;&#x52A0;&#x8F7D;,&#x522B;&#x4EBA;&#x5199;&#x7684;&#x901A;&#x8FC7;&#x540D;&#x79F0;&#x53BB;&#x5F53;&#x524D;&#x76EE;&#x5F55;&#x6216;&#x5168;&#x5C40;&#x7684;node_modules&#x4E0B;&#x9762;&#x53BB;&#x627E;</p>
</blockquote>
</li>
</ul>
<h3 id="t64.3 &#x7B2C;&#x4E09;&#x65B9;&#x6A21;&#x5757;">4.3 &#x7B2C;&#x4E09;&#x65B9;&#x6A21;&#x5757; <a href="#t64.3 &#x7B2C;&#x4E09;&#x65B9;&#x6A21;&#x5757;"> # </a></h3>
<ul>
<li>&#x5982;&#x679C;require&#x51FD;&#x6570;&#x53EA;&#x6307;&#x5B9A;&#x540D;&#x79F0;&#x5219;&#x89C6;&#x4E3A;&#x4ECE;node_modules&#x4E0B;&#x9762;&#x52A0;&#x8F7D;&#x6587;&#x4EF6;&#xFF0C;&#x8FD9;&#x6837;&#x7684;&#x8BDD;&#x4F60;&#x53EF;&#x4EE5;&#x79FB;&#x52A8;&#x6A21;&#x5757;&#x800C;&#x4E0D;&#x9700;&#x8981;&#x4FEE;&#x6539;&#x5F15;&#x7528;&#x7684;&#x6A21;&#x5757;&#x8DEF;&#x5F84;</li>
<li>&#x7B2C;&#x4E09;&#x65B9;&#x6A21;&#x5757;&#x7684;&#x67E5;&#x8BE2;&#x8DEF;&#x5F84;&#x5305;&#x62EC;module.paths&#x548C;&#x5168;&#x5C40;&#x76EE;&#x5F55;</li>
</ul>
<h4 id="t74.3.1 . &#x5168;&#x5C40;&#x76EE;&#x5F55;">4.3.1 . &#x5168;&#x5C40;&#x76EE;&#x5F55; <a href="#t74.3.1 . &#x5168;&#x5C40;&#x76EE;&#x5F55;"> # </a></h4>
<p>window&#x5982;&#x679C;&#x5728;&#x73AF;&#x5883;&#x53D8;&#x91CF;&#x4E2D;&#x8BBE;&#x7F6E;&#x4E86;<code>NODE_PATH</code>&#x53D8;&#x91CF;&#xFF0C;&#x5E76;&#x5C06;&#x53D8;&#x91CF;&#x8BBE;&#x7F6E;&#x4E3A;&#x4E00;&#x4E2A;&#x6709;&#x6548;&#x7684;&#x78C1;&#x76D8;&#x76EE;&#x5F55;&#xFF0C;require&#x5728;&#x672C;&#x5730;&#x627E;&#x4E0D;&#x5230;&#x6B64;&#x6A21;&#x5757;&#x65F6;&#x5411;&#x5728;&#x6B64;&#x76EE;&#x5F55;&#x4E0B;&#x627E;&#x8FD9;&#x4E2A;&#x6A21;&#x5757;&#x3002;
UNIX&#x64CD;&#x4F5C;&#x7CFB;&#x7EDF;&#x4E2D;&#x4F1A;&#x4ECE; $HOME/.node_modules $HOME/.node_libraries&#x76EE;&#x5F55;&#x4E0B;&#x5BFB;&#x627E;</p>
<h3 id="t84.4 &#x6A21;&#x5757;&#x7684;&#x52A0;&#x8F7D;&#x7B56;&#x7565;">4.4 &#x6A21;&#x5757;&#x7684;&#x52A0;&#x8F7D;&#x7B56;&#x7565; <a href="#t84.4 &#x6A21;&#x5757;&#x7684;&#x52A0;&#x8F7D;&#x7B56;&#x7565;"> # </a></h3>
<p><img src="http://img.zhufengpeixun.cn/lookmodule.png" alt="lookmodule"></p>
<h3 id="t94.5 &#x6587;&#x4EF6;&#x6A21;&#x5757;&#x67E5;&#x627E;&#x89C4;&#x5219;">4.5 &#x6587;&#x4EF6;&#x6A21;&#x5757;&#x67E5;&#x627E;&#x89C4;&#x5219; <a href="#t94.5 &#x6587;&#x4EF6;&#x6A21;&#x5757;&#x67E5;&#x627E;&#x89C4;&#x5219;"> # </a></h3>
<p><img src="http://img.zhufengpeixun.cn/lookfile.png" alt="lookmodule"></p>
<h2 id="t105. &#x4ECE;&#x6A21;&#x5757;&#x5916;&#x90E8;&#x8BBF;&#x95EE;&#x6A21;&#x5757;&#x5185;&#x7684;&#x6210;&#x5458;">5. &#x4ECE;&#x6A21;&#x5757;&#x5916;&#x90E8;&#x8BBF;&#x95EE;&#x6A21;&#x5757;&#x5185;&#x7684;&#x6210;&#x5458; <a href="#t105. &#x4ECE;&#x6A21;&#x5757;&#x5916;&#x90E8;&#x8BBF;&#x95EE;&#x6A21;&#x5757;&#x5185;&#x7684;&#x6210;&#x5458;"> # </a></h2>
<ul>
<li>&#x4F7F;&#x7528;exports&#x5BF9;&#x8C61;</li>
<li>&#x4F7F;&#x7528;module.exports&#x5BFC;&#x51FA;&#x5F15;&#x7528;&#x7C7B;&#x578B;</li>
</ul>
<h2 id="t116. &#x6A21;&#x5757;&#x5BF9;&#x8C61;&#x7684;&#x5C5E;&#x6027;">6. &#x6A21;&#x5757;&#x5BF9;&#x8C61;&#x7684;&#x5C5E;&#x6027; <a href="#t116. &#x6A21;&#x5757;&#x5BF9;&#x8C61;&#x7684;&#x5C5E;&#x6027;"> # </a></h2>
<ul>
<li>module.id</li>
<li>module.filename</li>
<li>module.loaded</li>
<li>module.parent</li>
<li>module.children</li>
<li>module.paths</li>
</ul>
<h2 id="t127. &#x5305;">7. &#x5305; <a href="#t127. &#x5305;"> # </a></h2>
<p>&#x5728;Node.js&#x4E2D;&#xFF0C;&#x53EF;&#x4EE5;&#x901A;&#x8FC7;&#x5305;&#x6765;&#x5BF9;&#x4E00;&#x7EC4;&#x5177;&#x6709;&#x76F8;&#x4E92;&#x4F9D;&#x8D56;&#x5173;&#x7CFB;&#x7684;&#x6A21;&#x5757;&#x8FDB;&#x884C;&#x7EDF;&#x4E00;&#x7BA1;&#x7406;&#x662F;&#xFF0C;&#x901A;&#x8FC7;&#x5305;&#x53EF;&#x4EE5;&#x628A;&#x67D0;&#x4E2A;&#x72EC;&#x7ACB;&#x529F;&#x80FD;&#x5C01;&#x88C5;&#x8D77;&#x6765;
&#x6BCF;&#x4E2A;&#x9879;&#x76EE;&#x7684;&#x6839;&#x76EE;&#x5F55;&#x4E0B;&#x9762;&#xFF0C;&#x4E00;&#x822C;&#x90FD;&#x6709;&#x4E00;&#x4E2A;package.json&#x6587;&#x4EF6;&#xFF0C;&#x5B9A;&#x4E49;&#x4E86;&#x8FD9;&#x4E2A;&#x9879;&#x76EE;&#x6240;&#x9700;&#x8981;&#x7684;&#x5404;&#x79CD;&#x6A21;&#x5757;&#xFF0C;&#x4EE5;&#x53CA;&#x9879;&#x76EE;&#x7684;&#x914D;&#x7F6E;&#x4FE1;&#x606F;&#xFF08;&#x6BD4;&#x5982;&#x540D;&#x79F0;&#x3001;&#x7248;&#x672C;&#x3001;&#x8BB8;&#x53EF;&#x8BC1;&#x7B49;&#x5143;&#x6570;&#x636E;&#xFF09;&#x3002;npm install&#x547D;&#x4EE4;&#x6839;&#x636E;&#x8FD9;&#x4E2A;&#x914D;&#x7F6E;&#x6587;&#x4EF6;&#xFF0C;&#x81EA;&#x52A8;&#x4E0B;&#x8F7D;&#x6240;&#x9700;&#x7684;&#x6A21;&#x5757;&#xFF0C;&#x4E5F;&#x5C31;&#x662F;&#x914D;&#x7F6E;&#x9879;&#x76EE;&#x6240;&#x9700;&#x7684;&#x8FD0;&#x884C;&#x548C;&#x5F00;&#x53D1;&#x73AF;&#x5883;</p>
<table>
<thead>
<tr>
<th style="text-align:left">&#x9879;&#x76EE;</th>
<th style="text-align:left">&#x63CF;&#x8FF0;</th>
</tr>
</thead>
<tbody>
<tr>
<td style="text-align:left">name</td>
<td style="text-align:left">&#x9879;&#x76EE;&#x540D;&#x79F0;</td>
</tr>
<tr>
<td style="text-align:left">version</td>
<td style="text-align:left">&#x7248;&#x672C;&#x53F7;</td>
</tr>
<tr>
<td style="text-align:left">description</td>
<td style="text-align:left">&#x9879;&#x76EE;&#x63CF;&#x8FF0;</td>
</tr>
<tr>
<td style="text-align:left">keywords: {Array}</td>
<td style="text-align:left">&#x5173;&#x952E;&#x8BCD;&#xFF0C;&#x4FBF;&#x4E8E;&#x7528;&#x6237;&#x641C;&#x7D22;&#x5230;&#x6211;&#x4EEC;&#x7684;&#x9879;&#x76EE;</td>
</tr>
<tr>
<td style="text-align:left">homepage</td>
<td style="text-align:left">&#x9879;&#x76EE;url&#x4E3B;&#x9875;</td>
</tr>
<tr>
<td style="text-align:left">bugs</td>
<td style="text-align:left">&#x9879;&#x76EE;&#x95EE;&#x9898;&#x53CD;&#x9988;&#x7684;Url&#x6216;email&#x914D;&#x7F6E;</td>
</tr>
<tr>
<td style="text-align:left">license</td>
<td style="text-align:left">&#x9879;&#x76EE;&#x8BB8;&#x53EF;&#x8BC1;</td>
</tr>
<tr>
<td style="text-align:left">author,contributors</td>
<td style="text-align:left">&#x4F5C;&#x8005;&#x548C;&#x8D21;&#x732E;&#x8005;</td>
</tr>
<tr>
<td style="text-align:left">main</td>
<td style="text-align:left">&#x4E3B;&#x6587;&#x4EF6;</td>
</tr>
<tr>
<td style="text-align:left">bin</td>
<td style="text-align:left">&#x9879;&#x76EE;&#x7528;&#x5230;&#x7684;&#x53EF;&#x6267;&#x884C;&#x6587;&#x4EF6;&#x914D;&#x7F6E;</td>
</tr>
<tr>
<td style="text-align:left">repository</td>
<td style="text-align:left">&#x9879;&#x76EE;&#x4EE3;&#x7801;&#x5B58;&#x653E;&#x5730;&#x65B9;</td>
</tr>
<tr>
<td style="text-align:left">scripts</td>
<td style="text-align:left">&#x58F0;&#x660E;&#x4E00;&#x7CFB;&#x5217;npm&#x811A;&#x672C;&#x6307;&#x4EE4;</td>
</tr>
<tr>
<td style="text-align:left">dependencies</td>
<td style="text-align:left">&#x9879;&#x76EE;&#x5728;&#x751F;&#x4EA7;&#x73AF;&#x5883;&#x4E2D;&#x4F9D;&#x8D56;&#x7684;&#x5305;</td>
</tr>
<tr>
<td style="text-align:left">devDependencies</td>
<td style="text-align:left">&#x9879;&#x76EE;&#x5728;&#x751F;&#x4EA7;&#x73AF;&#x5883;&#x4E2D;&#x4F9D;&#x8D56;&#x7684;&#x5305;</td>
</tr>
<tr>
<td style="text-align:left">peerDependencies</td>
<td style="text-align:left">&#x5E94;&#x7528;&#x8FD0;&#x884C;&#x4F9D;&#x8D56;&#x7684;&#x5BBF;&#x4E3B;&#x5305;</td>
</tr>
</tbody>
</table>
<p><a href="https://docs.npmjs.com/files/package.json">package.json</a>
<a href="http://javascript.ruanyifeng.com/nodejs/packagejson.html">packagejson</a></p>
<h2 id="t138. NPM">8. NPM <a href="#t138. NPM"> # </a></h2>
<p>&#x5B89;&#x88C5;&#x5B8C;node&#x4E4B;&#x540E;&#x53EA;&#x80FD;&#x4F7F;&#x7528;Node&#x8BED;&#x8A00;&#x7279;&#x6027;&#x53CA;&#x6838;&#x5FC3;&#x51FD;&#x6570;&#xFF0C;&#x6211;&#x4EEC;&#x8FD8;&#x9700;&#x8981;&#x4E00;&#x4E2A;&#x7CFB;&#x7EDF;&#x6765;&#x4E0B;&#x8F7D;&#x3001;&#x5B89;&#x88C5;&#x548C;&#x7BA1;&#x7406;&#x7B2C;&#x4E09;&#x65B9;&#x6A21;&#x5757;&#x3002;&#x5728; Node&#x770B;&#x8FD9;&#x4E2A;&#x7CFB;&#x7EDF;&#x88AB;&#x79F0;&#x4E3A;Node&#x5305;&#x7BA1;&#x7406;&#x5668;(Node Package Manager,NPM)&#x3002;</p>
<h3 id="t148.1 npm&#x63D0;&#x4F9B;&#x7684;&#x529F;&#x80FD;">8.1 npm&#x63D0;&#x4F9B;&#x7684;&#x529F;&#x80FD; <a href="#t148.1 npm&#x63D0;&#x4F9B;&#x7684;&#x529F;&#x80FD;"> # </a></h3>
<ul>
<li>&#x516C;&#x5171;&#x6CE8;&#x518C;&#x670D;&#x52A1;&#xFF0C;&#x7528;&#x6237;&#x53EF;&#x4EE5;&#x628A;&#x81EA;&#x5DF1;&#x5199;&#x7684;&#x5305;&#x4E0A;&#x4F20;&#x5230;&#x670D;&#x52A1;&#x5668;&#x4E0A;</li>
<li>&#x547D;&#x4EE4;&#x884C;&#x4E0B;&#x8F7D;&#x5DE5;&#x5177;&#xFF0C;&#x7528;&#x6237;&#x53EF;&#x4EE5;&#x901A;&#x8FC7;npm&#x547D;&#x4EE4;&#x628A;&#x522B;&#x4EBA;&#x5199;&#x7684;&#x5305;&#x4E0B;&#x8F7D;&#x5230;&#x81EA;&#x5DF1;&#x7535;&#x8111;&#x4E0A;&#xFF0C;&#x8FD8;&#x53EF;&#x4EE5;&#x7BA1;&#x7406;&#x81EA;&#x5DF1;&#x6A21;&#x5757;&#x4F9D;&#x8D56;&#x7684;&#x5176;&#x5B83;&#x6A21;&#x5757;</li>
</ul>
<p>&#x641C;&#x7D22;&#x7B2C;&#x4E09;&#x65B9;&#x5305;&#x7684;&#x5730;&#x5740;</p>
<pre><code>https://www.npmjs.com/search
</code></pre><h3 id="t158.2npm&#x547D;&#x4EE4;">8.2npm&#x547D;&#x4EE4; <a href="#t158.2npm&#x547D;&#x4EE4;"> # </a></h3>
<h5 id="t168.2.1 &#x5B89;&#x88C5;&#x5305;">8.2.1 &#x5B89;&#x88C5;&#x5305; <a href="#t168.2.1 &#x5B89;&#x88C5;&#x5305;"> # </a></h5>
<p>&#x6253;&#x5F00;&#x547D;&#x4EE4;&#x884C;&#x6216;&#x7EC8;&#x7AEF;&#xFF0C;&#x8FDB;&#x5165;&#x8981;&#x5B89;&#x88C5;&#x5305;&#x7684;&#x76EE;&#x5F55;,&#x7136;&#x540E;&#x6267;&#x884C;&#x4EE5;&#x4E0B;&#x547D;&#x4EE4;&#x5B89;&#x88C5;&#x4F9D;&#x8D56;&#x7684;&#x6A21;&#x5757;</p>
<pre><code>npm install &lt;package-name&gt;
npm i mime
</code></pre><p>&#x6B64;&#x547D;&#x4EE4;&#x4F1A;&#x4ECE;&#x670D;&#x52A1;&#x5668;&#x4E0A;&#x4E0B;&#x8F7D;&#x6B64;&#x6A21;&#x5757;&#x5230;&#x5F53;&#x524D;&#x76EE;&#x5F55;&#x4E0B;&#x7684;node_modules&#x76EE;&#x5F55;&#x4E0B;&#xFF0C;&#x5982;&#x679C;node_modules&#x76EE;&#x5F55;&#x4E0D;&#x5B58;&#x5728;&#x5219;&#x4F1A;&#x521B;&#x5EFA;&#x4E00;&#x4E2A;&#x3002;
&#x4E5F;&#x53EF;&#x4EE5;&#x5B89;&#x88C5;&#x7279;&#x5B9A;&#x7684;&#x7248;&#x672C;</p>
<pre><code>npm install &lt;package name&gt;@&lt;version spec&gt;
npm i mime@2.1
</code></pre><p>&#x8FD8;&#x53EF;&#x4EE5;&#x4F7F;&#x7528;&#x4E00;&#x4E2A;&#x7248;&#x672C;&#x53F7;&#x8303;&#x56F4;&#x6765;&#x66FF;&#x6362;<version spec="">&#x70B9;&#x4F4D;&#x7B26;&#x3002;</version></p>
<pre><code>npm i mime@2.x
</code></pre><h5 id="t178.2.2 &#x5378;&#x8F7D;&#x5305;">8.2.2 &#x5378;&#x8F7D;&#x5305; <a href="#t178.2.2 &#x5378;&#x8F7D;&#x5305;"> # </a></h5>
<pre><code>npm uninstall &lt;package name&gt;
</code></pre><h5 id="t188.2.3 &#x66F4;&#x65B0;&#x5305;">8.2.3 &#x66F4;&#x65B0;&#x5305; <a href="#t188.2.3 &#x66F4;&#x65B0;&#x5305;"> # </a></h5>
<p>&#x6211;&#x4EEC;&#x8FD8;&#x53EF;&#x4EE5;&#x901A;&#x8FC7;&#x4EE5;&#x4E0B;&#x6307;&#x4EE4;&#x66F4;&#x65B0;&#x5DF2;&#x7ECF;&#x5B89;&#x88C5;&#x7684;&#x5305;</p>
<pre><code>npm update &lt;package name&gt;
</code></pre><h3 id="t198.3&#x5305;&#x7684;&#x5B89;&#x88C5;&#x6A21;&#x5F0F;">8.3&#x5305;&#x7684;&#x5B89;&#x88C5;&#x6A21;&#x5F0F; <a href="#t198.3&#x5305;&#x7684;&#x5B89;&#x88C5;&#x6A21;&#x5F0F;"> # </a></h3>
<h4 id="t208.3.1 &#x672C;&#x5730;&#x5B89;&#x88C5;">8.3.1 &#x672C;&#x5730;&#x5B89;&#x88C5; <a href="#t208.3.1 &#x672C;&#x5730;&#x5B89;&#x88C5;"> # </a></h4>
<p>&#x9ED8;&#x8BA4;&#x60C5;&#x51B5;&#x4E0B;&#x5B89;&#x88C5;&#x547D;&#x4EE4;&#x4F1A;&#x628A;&#x5BF9;&#x5E94;&#x7684;&#x5305;&#x5B89;&#x88C5;&#x5230;&#x5F53;&#x524D;&#x76EE;&#x5F55;&#x4E0B;&#xFF0C;&#x8FD9;&#x53EB;&#x672C;&#x5730;&#x5B89;&#x88C5;&#xFF0C;&#x5982;&#x679C;&#x5305;&#x91CC;&#x6709;&#x53EF;&#x6267;&#x884C;&#x7684;&#x6587;&#x4EF6;NPM&#x4F1A;&#x628A;&#x53EF;&#x6267;&#x884C;&#x6587;&#x4EF6;&#x5B89;&#x88C5;&#x5230;<code>./node_modules/.bin</code>&#x76EE;&#x5F55;&#x4E0B;&#x3002;
&#x672C;&#x5730;&#x5B89;&#x88C5;&#x7684;&#x6A21;&#x5757;&#x53EA;&#x80FD;&#x5728;&#x5F53;&#x524D;&#x76EE;&#x5F55;&#x548C;&#x5F53;&#x524D;&#x76EE;&#x5F55;&#x7684;&#x5B50;&#x76EE;&#x5F55;&#x91CC;&#x9762;&#x4F7F;&#x7528;&#x3002;</p>
<h3 id="t218.4 &#x5168;&#x5C40;&#x5B89;&#x88C5;">8.4 &#x5168;&#x5C40;&#x5B89;&#x88C5; <a href="#t218.4 &#x5168;&#x5C40;&#x5B89;&#x88C5;"> # </a></h3>
<ul>
<li><p>&#x5982;&#x679C;&#x5E0C;&#x671B;&#x5B89;&#x88C5;&#x7684;&#x5305;&#x80FD;&#x591F;&#x5728;&#x8BA1;&#x7B97;&#x673A;&#x673A;&#x7684;&#x6240;&#x6709;&#x76EE;&#x5F55;&#x4E0B;&#x9762;&#x90FD;&#x80FD;&#x4F7F;&#x7528;&#x5C31;&#x9700;&#x8981;&#x5168;&#x5C40;&#x5B89;&#x88C5;&#x3002;</p>
<pre><code>npm install &lt;package-name&gt; -g
</code></pre></li>
<li><p>&#x5728;&#x5168;&#x5C40;&#x5B89;&#x88C5;&#x7684;&#x6A21;&#x5F0F;&#x4E0B;&#xFF0C;npm&#x4F1A;&#x628A;&#x5305;&#x5B89;&#x88C5;&#x5230;&#x5168;&#x5C40;&#x76EE;&#x5F55;&#xFF0C;&#x901A;&#x8FC7;&#x6B64;&#x547D;&#x4EE4;&#x53EF;&#x4EE5;&#x67E5;&#x770B;&#x5F53;&#x524D;&#x5168;&#x5C40;&#x76EE;&#x5F55;&#x7684;&#x4F4D;&#x7F6E;</p>
<pre><code>npm root -g
C:\Users\Administrator\AppData\Roaming\npm\node_modules
</code></pre></li>
<li><p>&#x5982;&#x679C;&#x8981;&#x4FEE;&#x6539;&#x5168;&#x5C40;&#x5B89;&#x88C5;&#x76EE;&#x5F55;&#xFF0C;&#x53EF;&#x4EE5;&#x4F7F;&#x7528;</p>
<pre><code>npm config set prefix &#x201C;D:\node.js\node_global&#x201D;
</code></pre></li>
<li><p>&#x5982;&#x679C;&#x5305;&#x91CC;&#x6709;&#x53EF;&#x6267;&#x884C;&#x6587;&#x4EF6;&#xFF0C;&#x4F1A;&#x628A;&#x53EF;&#x6267;&#x884C;&#x6587;&#x4EF6;&#x5B89;&#x88C5;&#x5230;&#x6B64;node_modules&#x7684;&#x4E0A;&#x4E00;&#x7EA7;&#x76EE;&#x5F55;&#x4E2D;&#x3002;</p>
<pre><code>C:\Users\Administrator\AppData\Roaming\npm\
</code></pre></li>
<li><p>&#x5168;&#x5C40;&#x5B89;&#x88C5;&#x7684;&#x4E00;&#x822C;&#x662F;&#x9700;&#x8981;&#x5728;&#x4EFB;&#x610F;&#x76EE;&#x5F55;&#x4E0B;&#x9762;&#x6267;&#x884C;&#x7684;&#x547D;&#x4EE4;&#xFF0C;&#x6BD4;&#x5982;<code>babel</code></p>
<pre><code>npm install babel-cli -g
</code></pre></li>
<li><p>&#x5982;&#x679C;&#x5168;&#x5C40;&#x5B89;&#x88C5;&#x7684;&#x547D;&#x4EE4;&#x4E0D;&#x80FD;&#x7528;&#x5219;&#x53EF;&#x80FD;&#x662F;&#x6CA1;&#x6709;&#x6B63;&#x786E;&#x914D;&#x7F6E;&#x7528;&#x6237;&#x53D8;&#x91CF;<code>PATH</code>,&#x9700;&#x8981;&#x5728;&#x7CFB;&#x7EDF;&#x53D8;&#x91CF;&#x4E2D;&#x4E3A;PATH&#x53D8;&#x91CF;&#x6DFB;&#x52A0;&#x5168;&#x5C40;&#x5B89;&#x88C5;&#x76EE;&#x5F55;</p>
</li>
<li><p>&#x9ED8;&#x8BA4;&#x60C5;&#x51B5;&#x4E0B;&#x5728;&#x5168;&#x5C40;&#x5B89;&#x88C5;&#x76EE;&#x5F55;&#x4E0B;&#x9762;&#x7684;&#x6A21;&#x5757;&#x662F;&#x4E0D;&#x80FD;&#x5728;&#x4EFB;&#x610F;&#x6587;&#x4EF6;&#x5939;&#x4E0B;&#x76F4;&#x63A5;&#x52A0;&#x8F7D;&#x7684;&#xFF0C;&#x5982;&#x679C;&#x60F3;&#x8981;&#x5728;&#x4EFB;&#x610F;&#x76EE;&#x5F55;&#x4E0B;&#x9762;&#x76F4;&#x63A5;&#x52A0;&#x8F7D;&#xFF0C;&#x9700;&#x8981;&#x5728;&#x7CFB;&#x7EDF;&#x53D8;&#x91CF;&#x4E2D;&#x65B0;&#x5EFA;&#x4E00;&#x4E2A;&#x540D;&#x4E3A;<code>NODE_PATH</code>&#x7684;&#x53D8;&#x91CF;&#xFF0C;&#x5B83;&#x7684;&#x503C;&#x4E3A;&#x5168;&#x5C40;&#x5B89;&#x88C5;&#x76EE;&#x5F55;&#x4E0B;&#x7684;<code>node_modules</code>&#x6240;&#x5728;&#x4F4D;&#x7F6E;&#x3002;</p>
</li>
</ul>
<h3 id="t228.5 &#x6CE8;&#x518C;&#x3001;&#x767B;&#x5F55;&#x548C;&#x53D1;&#x5E03;&#x6A21;&#x5757;">8.5 &#x6CE8;&#x518C;&#x3001;&#x767B;&#x5F55;&#x548C;&#x53D1;&#x5E03;&#x6A21;&#x5757; <a href="#t228.5 &#x6CE8;&#x518C;&#x3001;&#x767B;&#x5F55;&#x548C;&#x53D1;&#x5E03;&#x6A21;&#x5757;"> # </a></h3>
<ol>
<li>&#x6CE8;&#x518C;npm&#x8D26;&#x53F7;
<a href="https://www.npmjs.com/">https://www.npmjs.com/</a></li>
<li>&#x767B;&#x5F55;<pre><code>npm login
</code></pre></li>
<li>&#x53D1;&#x5E03;</li>
</ol>
<pre><code>npm publish
</code></pre><h2 id="t23&#x53C2;&#x8003;&#x8D44;&#x6599;">&#x53C2;&#x8003;&#x8D44;&#x6599; <a href="#t23&#x53C2;&#x8003;&#x8D44;&#x6599;"> # </a></h2>
<ul>
<li><a href="https://docs.npmjs.com/getting-started/what-is-npm">npm&#x5B98;&#x65B9;&#x624B;&#x518C;</a></li>
<li><a href="http://www.tuicool.com/articles/VB7nYn">npm&#x603B;&#x7ED3;</a></li>
</ul>
<h2 id="t249. yarn">9. yarn <a href="#t249. yarn"> # </a></h2>
<p>Yarn &#x662F;&#x4E00;&#x4E2A;&#x4F9D;&#x8D56;&#x7BA1;&#x7406;&#x5DE5;&#x5177;&#x3002;&#x5B83;&#x80FD;&#x591F;&#x7BA1;&#x7406;&#x4F60;&#x7684;&#x4EE3;&#x7801;&#xFF0C;&#x5E76;&#x4E0E;&#x5168;&#x4E16;&#x754C;&#x7684;&#x5F00;&#x53D1;&#x8005;&#x5206;&#x4EAB;&#x4EE3;&#x7801;&#x3002;
&#x4EE3;&#x7801;&#x662F;&#x901A;&#x8FC7;&#x5305;&#xFF08;&#x6709;&#x65F6;&#x4E5F;&#x88AB;&#x79F0;&#x4E3A;&#x6A21;&#x5757;&#xFF09;&#x8FDB;&#x884C;&#x5171;&#x4EAB;&#x7684;&#x3002; &#x5728;&#x6BCF;&#x4E00;&#x4E2A;&#x5305;&#x4E2D;&#x5305;&#x542B;&#x4E86;&#x6240;&#x6709;&#x9700;&#x8981;&#x5171;&#x4EAB;&#x7684;&#x4EE3;&#x7801;&#xFF0C;&#x53E6;&#x5916;&#x8FD8;&#x5B9A;&#x4E49;&#x4E86;&#x4E00;&#x4E2A;<code>package.json</code>&#x6587;&#x4EF6;&#xFF0C;&#x7528;&#x6765;&#x63CF;&#x8FF0;&#x8FD9;&#x4E2A;&#x5305;&#x3002;</p>
<h3 id="t259.1 &#x521D;&#x59CB;&#x5316;&#x4E00;&#x4E2A;&#x65B0;&#x7684;&#x9879;&#x76EE;">9.1 &#x521D;&#x59CB;&#x5316;&#x4E00;&#x4E2A;&#x65B0;&#x7684;&#x9879;&#x76EE; <a href="#t259.1 &#x521D;&#x59CB;&#x5316;&#x4E00;&#x4E2A;&#x65B0;&#x7684;&#x9879;&#x76EE;"> # </a></h3>
<pre><code>yarn init
</code></pre><h3 id="t269.2 &#x6DFB;&#x52A0;&#x4E00;&#x4E2A;&#x4F9D;&#x8D56;&#x5305;">9.2 &#x6DFB;&#x52A0;&#x4E00;&#x4E2A;&#x4F9D;&#x8D56;&#x5305; <a href="#t269.2 &#x6DFB;&#x52A0;&#x4E00;&#x4E2A;&#x4F9D;&#x8D56;&#x5305;"> # </a></h3>
<pre><code>yarn add [package]
yarn add [package]@[version]
yarn add [package]@[tag]
</code></pre><h3 id="t279.3 &#x66F4;&#x65B0;&#x4E00;&#x4E2A;&#x4F9D;&#x8D56;&#x5305;">9.3 &#x66F4;&#x65B0;&#x4E00;&#x4E2A;&#x4F9D;&#x8D56;&#x5305; <a href="#t279.3 &#x66F4;&#x65B0;&#x4E00;&#x4E2A;&#x4F9D;&#x8D56;&#x5305;"> # </a></h3>
<pre><code>yarn upgrade [package]
yarn upgrade [package]@[version]
yarn upgrade [package]@[tag]
</code></pre><h3 id="t289.4 &#x5220;&#x9664;&#x4E00;&#x4E2A;&#x4F9D;&#x8D56;&#x5305;">9.4 &#x5220;&#x9664;&#x4E00;&#x4E2A;&#x4F9D;&#x8D56;&#x5305; <a href="#t289.4 &#x5220;&#x9664;&#x4E00;&#x4E2A;&#x4F9D;&#x8D56;&#x5305;"> # </a></h3>
<pre><code>yarn remove [package]
</code></pre><h3 id="t299.5 &#x5B89;&#x88C5;&#x6240;&#x6709;&#x7684;&#x4F9D;&#x8D56;&#x5305;">9.5 &#x5B89;&#x88C5;&#x6240;&#x6709;&#x7684;&#x4F9D;&#x8D56;&#x5305; <a href="#t299.5 &#x5B89;&#x88C5;&#x6240;&#x6709;&#x7684;&#x4F9D;&#x8D56;&#x5305;"> # </a></h3>
<pre><code>yarn
</code></pre><p>&#x6216;&#x8005;</p>
<pre><code>yarn install
</code></pre><h2 id="t30&#x53C2;&#x8003;">&#x53C2;&#x8003; <a href="#t30&#x53C2;&#x8003;"> # </a></h2>
<ul>
<li><a href="https://yarn.bootcss.com/">yarn</a></li>
</ul>

        <div class="copyright">Powered by <a href="https://github.com/jaywcjlove/idoc" target="_blank">idoc</a>. Dependence <a href="https://nodejs.org">Node.js</a> run.</div>
    </div>
    
</div>

<script src="https://cdn.bootcss.com/jquery/3.0.0/jquery.js"></script>
<script>
$('.warpper .page-toc ul ul li a').on('click',function(){
  $('.warpper .page-toc ul ul li a').removeClass('my-active')
  $(this).addClass('my-active')
})
  // if (!$('.understand-me').length) {
  //   var bar = $(window).height() - $('.navbar ').height() - $('.page-toc').position().top;
  //   var count = bar / 26 / 2;
  //   var barHeight = $('.page-toc').outerHeight();
  //   $('.page-toc li').eq(0).children('a').addClass('red');
  //   var arr = [];
  //   $("h1,h2,h3,h4,h5,h6").each(function () {
  //     arr.push($(this).position().top);
  //   });
  //   var timer
  //   function dark() {
  //     clearTimeout(timer)
  //      timer = setTimeout(function () {
  //      var top = Math.abs($('.page-toc > ul').position().top);
  //      var cur = $('.content').scrollTop();
  //      for (var i = arr.length; i >= 0; i--) {
  //        if (arr[i] <= cur) {
  //          break;
  //        }
  //      }
  //      if (i === -1) {
  //        i = 0;
  //      }
  //      $('.page-toc li a').removeClass('red');
  //      $('.page-toc li').eq(i).children('a').addClass('red');
  //      let height = $('.page-toc li').eq(i).position().top-$('.page-toc').height(); // 如果当前的offset出去了 回到中间可好？
  //      $('.page-toc').scrollTop(height+$('.page-toc').height()/2);
  //    },200)
  //   }

  //   $('.content').on('scroll', dark);
  // }
</script>
<style>

    /* ::-webkit-scrollbar{width:14px;}
    ::-webkit-scrollbar-track{background-color:transparent;}
    ::-webkit-scrollbar-thumb{background-color:transparent;}
    ::-webkit-scrollbar-thumb:hover {background-color:transparent}
    ::-webkit-scrollbar-thumb:active {background-color:transparent} */

    .page-toc > ul .red {
        background: #f3f3f3;
        z-index: 1;
        border-left: 3px solid #009a61;
        -webkit-transition: all .2s ease;
        transition: all .2s ease;
        color: #000
    }





</style>
</body>
</html>
